package com.sinosoft.lk.core.config;

import redis.clients.jedis.JedisPoolConfig;

/**
 * @Author 绫小路
 * @Date 2021/3/4
 */
public class SsoDefaultJedisConfig extends JedisPoolConfig {
  @Override
  public void setBlockWhenExhausted(boolean blockWhenExhausted) {
    //默认true
    super.setBlockWhenExhausted(true);
  }

  @Override
  public void setMaxWaitMillis(long maxWaitMillis) {
    //获取连接时的最大等待毫秒数(如果设置为阻塞时BlockWhenExhausted),如果超时就抛异常, 小于零:阻塞不确定的时间,  默认-1
    super.setMaxWaitMillis(10000L);
  }

  @Override
  public void setMinEvictableIdleTimeMillis(long minEvictableIdleTimeMillis) {
    //逐出连接的最小空闲时间 默认1800000毫秒(30分钟)
    super.setMinEvictableIdleTimeMillis(60000L);
  }
}
/**
 * https://www.cnblogs.com/jklk/p/7095067.html
 * JedisPoolConfig config = new JedisPoolConfig();
 * <p>
 * //连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true
 * config.setBlockWhenExhausted(true);
 * <p>
 * //设置的逐出策略类名, 默认DefaultEvictionPolicy(当连接超过最大空闲时间,或连接数超过最大空闲连接数)
 * config.setEvictionPolicyClassName("org.apache.commons.pool2.impl.DefaultEvictionPolicy");
 * <p>
 * //是否启用pool的jmx管理功能, 默认true
 * config.setJmxEnabled(true);
 * <p>
 * //MBean ObjectName = new ObjectName("org.apache.commons.pool2:type=GenericObjectPool,name=" + "pool" + i); 默 认为"pool", JMX不熟,具体不知道是干啥的...默认就好.
 * config.setJmxNamePrefix("pool");
 * <p>
 * //是否启用后进先出, 默认true
 * config.setLifo(true);
 * <p>
 * //最大空闲连接数, 默认8个
 * config.setMaxIdle(8);
 * <p>
 * //最大连接数, 默认8个
 * config.setMaxTotal(8);
 * <p>
 * //获取连接时的最大等待毫秒数(如果设置为阻塞时BlockWhenExhausted),如果超时就抛异常, 小于零:阻塞不确定的时间,  默认-1
 * config.setMaxWaitMillis(-1);
 * <p>
 * //逐出连接的最小空闲时间 默认1800000毫秒(30分钟)
 * config.setMinEvictableIdleTimeMillis(1800000);
 * <p>
 * //最小空闲连接数, 默认0
 * config.setMinIdle(0);
 * <p>
 * //每次逐出检查时 逐出的最大数目 如果为负数就是 : 1/abs(n), 默认3
 * config.setNumTestsPerEvictionRun(3);
 * <p>
 * //对象空闲多久后逐出, 当空闲时间>该值 且 空闲连接>最大空闲数 时直接逐出,不再根据MinEvictableIdleTimeMillis判断  (默认逐出策略)
 * config.setSoftMinEvictableIdleTimeMillis(1800000);
 * <p>
 * //在获取连接的时候检查有效性, 默认false
 * config.setTestOnBorrow(false);
 * <p>
 * //在空闲时检查有效性, 默认false
 * config.setTestWhileIdle(false);
 * <p>
 * //逐出扫描的时间间隔(毫秒) 如果为负数,则不运行逐出线程, 默认-1
 * config.setTimeBetweenEvictionRunsMillis(-1);
 * <p>
 * JedisPool pool = new JedisPool(config, "localhost",);
 * <p>
 * int timeout=3000;
 * new JedisSentinelPool(master, sentinels, poolConfig,timeout);//timeout 读取超时
 */
